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Abstract 

The A-calculus is considered an useful mathematical tool in the study of programming 
languages, since programs can be identified with A-terms. However, if one goes further and 
uses /3r?-conversion to prove equivalence of programs, then a gross simplification is introduced 
(programs are identified with total functions from values to values), that may jeopardise the 
applicability of theoretical results. In this paper we introduce calculi based on a categorical 
semantics for computations, that provide a correct basis for proving equivalence of programs, 
for a wide range of notions of computation. 


Introduction 

This paper is about logics for reasoning about programs, in particular for proving equivalence of 
programs. Following a consolidated tradition in theoretical computer science we identify programs 
with the closed A-terms, possibly containing extra constants, corresponding to some features of 
the programming language under consideration. There are three semantic-based approaches to 
proving equivalence of programs: 

• The operational approach starts from an operational semantics, e.g. a partial function 
mapping every program (i.e. closed term) to its resulting value (if any), which induces a 
congruence relation on open terms called operational equivalence (see e.g. [Plo75]). Then 
the problem is to prove that two terms are operationally equivalent. 

• The denotational approach gives an interpretation of the (programming) language in a 
mathematical structure, the intended model. Then the problem is to prove that two terms 
denote the same object in the intended model. 

• The logical approach gives a class of possible models for the (programming) language. 
Then the problem is to prove that two terms denotes the same object in all possible models. 

The operational and denotational approaches give only a theory: the operational equivalence « 
or the set Th of formulas valid in the intended model respectively. On the other hand, the logical 
approach gives a consequence relation h, namely Ax I- A iff the formula A is true in all models 
of the set of formulas Ax, which can deal with different programming languages (e.g. functional, 
imperative, non-deterministic) in a rather uniform way, by simply changing the set of axioms 
Ax, and possibly extending the language with new constants. Moreover, the relation I- is often 
semidecidable, so it is possible to give a sound and complete formal system for it, while Th and « 
are semidecidable only in oversimplified cases. 

We do not take as a starting point for proving equivalence of programs the theory of /377- 
conversion, which identifies the denotation of a program (procedure) of type A —> B with a 
total function from A to B, since this identification wipes out completely behaviours like non¬ 
termination, non-determinism or side-effects, that can be exhibited by real programs. Instead, we 
proceed as follows: 

1. We take category theory as a general theory of functions and develop on top a categorical 
semantics of computations based on monads. 
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2. We consider simple formal systems matching the categorical semantics of computation. 

3. We extend stepwise categorical semantics and formal system in order to interpret richer 
languages, in particular the A-calculus. 

4. We show that w.l.o.g. one may consider only (monads over) toposes, and we exploit this fact 
to establish conservative extension results. 

The methodology outlined above is inspired by [SC 08 O] 1 , and it is followed in [Ros 86 , Mog 86 ] to 
obtain the A p -calculus. The view that “category theory comes, logically, before the A-calculus”led 
us to consider a categorical semantics of computations first, rather than to modify directly the 
rules of /^conversion to get a correct calculus. 

Related work 

The operational approach to find correct A-calculi w.r.t. an operational equivalence, was first 
considered in [Plo75] for call-by-value and call-by-name operational equivalence. This approach 
was later extended, following a similar methodology, to consider other features of computations like 
nondeterminism (see [Sha84]), side-effects and continuations (see [FFKD 86 , FF89]). The calculi 
based only on operational considerations, like the A v -calculus, are sound and complete w.r.t. the 
operational semantics, i.e. a program M has a value according to the operational semantics iff it 
is provably equivalent to a value (not necessarily the same) in the calculus, but they are too weak 
for proving equivalences of programs. 

Previous work on axiom systems for proving equivalence of programs with side effects has 
shown the importance of the tef-constructor (see [Mas 88 , MT89a, MT89b]). In the framework of 
the computational lambda-calculus the importance of let becomes even more apparent. 

The denotational approach may suggest important principles, e.g. fix-point induction (see 
[Sco69, GMW79]), that can be found only after developing a semantics based on mathematical 
structures rather than term models, but it does not give clear criteria to single out the general 
principles among the properties satisfied by the model. Moreover, the theory at the heart of De¬ 
notational Semantics, i.e. Domain Theory (see [GS89, Mos89]), has focused on the mathematical 
structures for giving semantics to recursive definitions of types and functions (see [SP82]), while 
other structures, that might be relevant to a better understanding of programming languages, have 
been overlooked. This paper identify one of such structures, i.e. monads, but probably there are 
others just waiting to be discovered. 

The categorical semantic of computations presented in this paper has been strongly influenced 
by the reformulation of Denotational Semantics based on the category of epos, possibly without 
bottom, and partial continuous functions (see [Plo85]) and the work on categories of partial mor- 
phisms in [Ros 86 , Mog 86 ]. Our work generalises the categorical account of partiality to other 
notions of computations, indeed partial cartesian closed categories turn out to be a special case of 
A c -models (see Definition 3.9). 

A type theoretic approach to partial functions and computations is proposed in [CS87, CS 88 ] 
by introducing a type-constructor A, whose intuitive meaning is the set of computations of type 
A. Our categorical semantics is based on a similar idea. Constable and Smith, however, do not 
adequately capture the general axioms for computations (as we do), since their notion of model, 
based on an untyped partial applicative structure, accounts only for partial computations. 


1 A categorical semantics of computations 

The basic idea behind the categorical semantics below is that, in order to interpret a programming 
language in a category C, we distinguish the object A of values (of type A) from the object TA of 


1 “I am trying to find out where A-calculus should come from, and the fact that the notion of a cartesian closed 
category is a late developing one (Eilenberg & Kelly (1966)), is not relevant to the argument: I shall try to explain 
in my own words in the next section why we should look to it first”. 
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computations (of type A ), and take as denotations of programs (of type A) the elements of TA. 
In particular, we identify the type A with the object of values (of type A) and obtain the object 
of computations (of type A) by applying an unary type-constructor T to A. We call T a notion 
of computation, since it abstracts away from the type of values computations may produce. There 
are many choices for TA corresponding to different notions of computations. 

Example 1.1 We give few notions of computation in the category of sets. 

• partiality TA = A± (i.e. A + {_!_}), where _L is the diverging computation 

• nondeterminism TA = Vfi n {A) 

• side-effects TA = (Ax S) s , where S' is a set of states, e.g. a set U L of stores or a set of 
input/output sequences U* 

• exceptions TA = (A + E), where E is the set of exceptions 

• continuations TA = Rf R K where R is the set of results 

• interactive input TA = (pry.A + 7^), where U is the set of characters. 

More explicitly TA is the set of [/-branching trees with finite branches and A-labelled leaves 

• interactive output TA = (/ry.A + (U x 7)). 

More explicitly TA is (isomorphic to) U* x A. 

Further examples (in a category of epos) could be given based on the denotational semantics for 
various programming languages (see [Sch86, GS89, Mos89]). 

Rather than focusing on a specific T, we want to find the general properties common to all notions 
of computation, therefore we impose as only requirement that programs should form a category. 
The aim of this section is to convince the reader, with a sequence of informal argumentations, that 
such a requirement amounts to say that T is part of a Kleisli triple (T, 17, _*) and that the category 
of programs is the Kleisli category for such a triple. 

Definition 1.2 ([Man76]) A Kleisli triple over a category C is a triple (T, 77, _*), whereT: Obj(C) 
Obj(C), tja- A —> TA for A 6 . Obj(C), /*: TA —► TE for f: A —► TB and the following equations 
hold: 


• V A', f*=f for f: A—> TB 

• /*; 9* = (/; g*T for f-.A^TB and g:B TC. 

A Kleisli triple satisfies the mono requirement provided rjA is mono for A £ C. 

Intuitively tja is the inclusion of values into computations (in several cases rjA is indeed a mono) and 
/* is the extension of a function / from values to computations to a function from computations 
to computations, which first evaluates a computation and then applies / to the resulting value. In 
summary 

a: A A [a]: TA 

a: A f(a):TB _ 

c: TA hC (let x<=cin f(x)):TB 

In order to justify the axioms for a Kleisli triple we have first to introduce a category Ct whose 
morphisms correspond to programs. We proceed by analogy with the categorical semantics for 
terms, where types are interpreted by objects and terms of type B with a parameter (free variable) 
of type A are interpreted by morphisms from A to B. Since the denotation of programs of type B 
are supposed to be elements of TB, programs of type B with a parameter of type A ought to be 
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interpreted by morphisms with codomain TB, but for their domain there are two alternatives, either 
d or Ti, depending on whether parameters of type A are identified with values or computations 
of type A. We choose the first alternative, because it entails the second. Indeed computations 
of type A are the same as values of type TA. So we take Ct(A,B ) to be C(A,TB). It remains 
to define composition and identities in Ct (and show that they satisfy the unit and associativity 
axioms for categories). 

Definition 1.3 Given a Kleisli triple (T, rj, _*) over C, the Kleisli category Ct is defined as 
follows: 

• the objects of Ct are those of C 

• the set Ct{A, B) of morphisms from A to B in Ct is C(A,TB) 

• the identity on A in Ct is t)a' A —> T A 

• fe C t {A , B) followed by g e C T (B, C ) in C T is /; g*: A -> TC. 

It is natural to take t]a as the identity on A in the category Ct, since it maps a parameter x to [ar], 
i.e. to x viewed as a computation. Similarly composition in Ct has a simple explanation in terms 
of the intuitive meaning of /*, in fact 

x:A^f(x):TB y:B^g(y):TC 
x: A (let y<=f(x) mg(y)): TC 

i.e. / followed by g in Ct with parameter x is the program which first evaluates the program 
f(x) and then feed the resulting value as parameter to g. At this point we can give also a simple 
justification for the three axioms of Kleisli triples, namely they are equivalent to the unit and 
associativity axioms for Ct- 

• f', r l*B = f for f-A—* TB 

• r] A m , f* = f for f:A—> TB 

• (/; 0*); h* = /; (g; h*)* for f:A-> TB, g:B^TC and h: C -► TD. 

Example 1.4 We go through the notions of computation given in Example 1.1 and show that they 
are indeed part of suitable Kleisli triples. 

• partiality TA = Aj_(= A + {_L}) 
t]a is the inclusion of A into A± 

if /: A —> TB, then /*(_L) = _L and f*(a) = f(a) (when a £ A) 

• nondeterminism TA = Vfi n {A) 
r/A is the singleton map a 1—> {a} 

if /: A —> TB and c € TA, then f*(c) = U xec f(x) 

• side-effects TA = (Ax S) s 
r/A is the map a 1—> (As: S.(a, s)) 

if /: A —> TB and c 6 TA, then f*(c) = As: S'.(let (a, s') = c(s) in f(a) (s')) 

• exceptions TA = (A + E) 

t]a is the injection map a 1—> inl(a) 

if /: A —* TB, then /*(inr(e)) = e (when e £ E) and /*(inl(a)) = f(a) (when a £ A) 

• continuations TA = R( r ) 

r/A is the map a 1—> (A k: R A .k(a)) 

if /: A -> TB and c € TA, then /*(c) = (A k: R B .c(Xa: A.f(a)(k))) 



• interactive input TA = (pg.A + j u ) 

g a maps a to the tree consisting only of one leaf labelled with a 

if f: A TB and c £ TA, then /*(c) is the tree obtained by replacing leaves of c labelled 
by a with the tree /(a) 

• interactive output TA = (/ry .A + (U x 7)) 
t]a is the map a 1—> (e, a) 

if f: A —> TB, then f*((s, a)) = (s* s', b), where f(a) = (s', b) and s * s' is the concatenation 
of s followed by s'. 

Kleisli triples are just an alternative description for monads. Although the formers are easy 
to justify from a computational perspective, the latters are more widely used in the literature on 
Category Theory and have the advantage of being defined only in terms of funtors and natural 
transformations, which make them more suitable for abstract manipulation. 

Definition 1.5 ([Mac71]) A monad over a category C is a triple (T, g,p), where T:C—>C is 
a functor, g: Idc -A T and p:T 2 —> T are natural transformations and the following diagrams 
commute: 



PA 

Proposition 1.6 ([Man76]) There is a one-one correspondence between Kleisli triples and mon¬ 
ads. 

Proof Given a Kleisli triple (T, g, _*), the corresponding monad is (T, g, p), where T is the extension 
of the function T to an endofunctor by taking T(f) = (/; gs)* for f: A —> B and pa = id^ 4 . 
Conversely, given a monad (T,g,p), the corresponding Kleisli triple is (T, g, _*), where T is the 
restriction of the functor T to objects and /* = (T/); ps for /: A —> TB. I 

Remark 1.7 In general the categorical semantics of partial maps, based on a category C equipped 
with a dominion M. (see [Ros86]), cannot be reformulated in terms of a Kleisli triple over C 
satisfying some additional properties, unless C has lifting, i.e. the inclusion functor from C into the 
category of partial maps P(C, Af) has a right adjoint __l characterised by the natural isomorphism 

C(A,B ± ) *P(C,M)(A,B) 

This mismatch disappears when considering partial cartesian closed categories. 

2 Simple languages for monads 

In this section we consider two formal systems motivated by different objectives: reasoning about 
programming languages and reasoning about programs in a fixed programming language. When 
reasoning about programming languages one has different monads (for simplicity we assume that 
they are over the same category), one for each programming language, and the main aim is to 
study how they relate to each other. So it is natural to base a formal system on a metalanguage 
for a category and treat monads as unary type-constructors. When reasoning about programs one 
has only one monad, because the programming language is fixed, and the main aim is to prove 
properties of programs. In this case the obvious choice for the term language is the programming 
language itself, which is more naturally interpreted in the Kleisli category. 
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Remark 2.1 We regard the metalanguage as more fundamental. In fact, its models are more 
general, as they don’t have to satisfy the mono requirement, and the interpretation of programs (of 
some given programming language) can be defined simply by translation into (a suitable extension 
of) the metalanguage. It should be pointed out that the mono requirement cannot be axiomatised 
in the metalanguage, as we would need conditional equations [x]t = [v]t —> x = y, and that 
existence assertions cannot be translated into formulas of the metalanguage, as we would need 
existentially quantified formulas (e J. CT )° = (Ax: a.e° = [x]t) 2 - 

In Section 2.3 we will explain once for all the correspondence between theories of a simple 
programming language and categories with a monad satisfying the mono requirement. For other 
programming languages we will give only their translation in a suitable extension of the metalan¬ 
guage. In this way, issues like call-by-value versus call-by-name affect the translation, but not the 
metalanguage. 

In Categorical Logic it is common practice to identify a theory T with a category !F(T) with 
additional structure such that there is a one-one correspondence between models of T in a category 
C with additional structure and structure preserving functors from T(T) to C (see [KR77]) 3 . This 
identification was originally proposed by Lawvere, who also showed that algebraic theories can be 
viewed as categories with finite products. 

In Section 2.2 we give a class of theories that can be viewed as categories with a monad, so that 
any category with a monad is, up to equivalence (of categories with a monad), one of such theories. 
Such a reformulation in terms of theories is more suitable for formal manipulation and more 
appealing to those unfamiliar with Category Theory. However, there are other advantages in having 
an alternative presentation of monads. For instance, natural extensions of the syntax may suggest 
extensions of the categorical structure that may not be immediate to motivate and justify otherwise 
(we will exploit this in Section 3). In Section 2.3 we take a programming language perspective 
and establish a correspondence between theories (with equivalence and existence assertions) for a 
simple programming language and categories with a monad satisfying the mono requirement, i.e. 
r)A mono for every A. 

As starting point we take many sorted monadic equational logic , because it is more primitive 
than many sorted equational logic, indeed monadic theories are equivalent to categories without 
any additional structure. 


2.1 Many sorted monadic equational logic 

The language and formal system of many sorted monadic equational logic are parametric in a 
signature, i.e. a set of base types A and unary function symbols f: Ai —> A 2 . The language is made 
of types h A type, terms x: Ai b e: A 2 and equations x: Ai b e\ =a 2 e 2 defined by the following 
formation rules: 


b A type 
x: A b x: A 

, rAbepAi t A A 
rAbf(ei):A 2 : 1 ^ 2 

x: Ai b e\\ A 2 x: Ai b e 2 : A 2 


2 The uniqueness of x s.t. .efyb \x]t follows from the mono requirement. 

3 In [LS86] a stronger relation is sought between theories and categories with additional structure, namely an 
equivalence between the category of theories and translations and the category of small categories with additional 
structure and structure preserving functors. In the case of typed A-calculus, for instance, such an equivalence 
between A-theories and cartesian closed categories requires a modification in the definition of A-theory, which allows 
not only equations between A-terms but also equations between type expressions. 
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RULE 

SYNTAX 

SEMANTICS 

A 




b A type 

= [A] 

var 

b A type 

= c 


x: A b x: A 

= id c 

f: Ai —> A 2 

i:Ab e\\ Ai 

= 9 


x:Abf(e 1 ):A 2 

= 9\ [f] 

eq 

x: Ai b er. A 2 

= 9i 


x: Ai b e 2 : A 2 

= 92 


x: Ai b ei =a 2 e2 

<*=> 9i = 92 


Table 1: Interpretation of Many Sorted Monadic Equational Language 


Remark 2.2 Terms of (many sorted) monadic equational logic have exactly one free variable (the 
one declared in the context) which occurs exactly once, and equations are between terms with the 
same free variable. 

An interpretation [_] of the language in a category C is parametric in an interpretation of the 
symbols in the signature and is defined by induction on the derivation of well-formedness for 
(types,) terms and equations (see Table 1) according to the following general pattern: 

• the interpretation [A] of a base type A is an object of C 

• the interpretation [f] of an unary function f: Ai —> A2 is a morphism from [Ai] to [A2] in 
C: similarly for the interpretation of a term x: Ai b e: A2 

• the interpretation of an assertion x: A b <f> (in this case just an equation) is either true or 
false. 


Remark 2.3 The interpretation of equations is standard. However, if one want to consider more 
complex assertions, e.g. formulas of first order logic, then they should be interpreted by subobjects; 
in particular equality _ = A should be interpreted by the diagonal Aj A j. 

The formal consequence relation on the set of equations is generated by the inference rules for 
equivalences ((refl), (simm) and (trans)), congruence and substitutivity (see Table 2). This formal 
consequence relation is sound and complete w.r.t. interpretation of the language in categories, i.e. 
an equation is formally derivable from a set of equational axioms if and only if all the interpretations 
satisfying the axioms satisfy the equation. Soundness follows from the admissibility of the inference 
rules in any interpretation, while completeness follows from the fact that any theory T (i.e. a set 
of equations closed w.r.t. the inference rules) is the set of equations satisfied by the canonical 
interpretation in the category F{T), i.e. T viewed as a category. 

Definition 2.4 Given a monadic equational theory T, the category iF(T) is defined as follows: 

• objects are (base) types A, 

• morphisms from Ai to A2 are equivalence classes [a;:Ai b e:A2] r of terms w.r.t. the equiv¬ 
alence relation induced by the theory T, i.e. 


(x: Ai b ep A 2 ) = {x: Ai b e 2 : A 2 ) •<=>• (x: Ai b ei =a 2 e 2 ) € T 






refl 


x: A b e: A] 
::Ahe = Al 


trans ■ 

congr ■ 

subst 


A I- e\ =A : 


A I- e 2 =Ai ei 

A I- ei = Al e 2 x: A b e 2 =A t e 3 
x: A h e 2 =Ai e 3 
x:Ahe,= a ,e 2 £A ^ 


x:Ab£( ei ) =a 2 f(e ; 
x: A b e: Ai x: Ai b (j> 
x: A b [e/x]</> 

Table 2: Inference Rules of Many Sorted Monadic Equational Logic 


• composition is substitution, i.e. 

[x: Ai b ei: A 2 ] r ; [x: A 2 b e 2 : A 3 ] r = [x: Ai b [ei/x]e 2 : A 3 ] r 

• identity over A is [x: A b x: A] r . 

There is also a correspondence in the opposite direction, namely every category C (with additional 
structure) can be viewed as a theory Tc (i.e. the theory of C over the language for C), so that C and 
tF(Tc) are equivalent as categories (with additional structure). Actually, in the case of monadic 
equational theories and categories, C and T{Tc) are isomorphic. 

In the sequel we consider other equational theories. They can be viewed as categories in the 
same way described above for monadic theories; moreover, these categories are equipped with 
additional structure, depending on the specific nature of the theories under consideration. 

2.2 The Simple metalanguage 

We extend many sorted monadic equational logic to match categories equipped with a monad (or 
equivalently a Kleisli triple). Although we consider only one monad, it is conceptually straightfor¬ 
ward to have several monads at once. 

The first step is to extend the language. This could be done in several ways without affecting 
the correspondence between theories and monads, we choose a presentation inspired by Kleisli 
triples, more specifically we introduce an unary type-constructor T and the two term-constructors, 
[_] and let, used informally in Section 1. The definition of signature is slightly modified, since the 
domain and codomain of an unary function symbol f: n —> r 2 can be any type, not just base types 
(the fact is that in many sorted monadic logic the only types are base types). An interpretation 
[_] of the language in a category C with a Kleisli triple (T, 7], _*) is parametric in an interpretation 
of the symbols in the signature and is defined by induction on the derivation of well-formedness 
for types, terms and equations (see Table 3). Finally we add to many sorted monadic equational 
logic appropriate inference rules capturing axiomatically the properties of the new type- and term- 
constructors after interpretation (see Table 4). 

Proposition 2.5 Every theory T of the simple metalanguage, viewed as a category E{T), is 
equipped with a Kleisli triple (T, rj, _*): 

• T(r) = Tt, 

• Vt= [x:t b m ; [x] t :Tt] t , 

• ([x:ti b m i e:Tr 2 ] r )* = [x'\Tt\ b m i (letr x<S=x'ine):Tr 2 ] r . 
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Proof We have to show that the three axioms for Kleisli triples are valid. The validity of each 
axiom amounts to the derivability of an equation. For instance, rj* = \&tt is valid provided 
x':Tt b m i (letr xA=x! in [a:] t) =t t x ' is derivable, indeed it follows from (T.rj). The reader can 
check that the equations corresponding to the axioms tj T : /* = / and /*; g* = (/; g*)* follow from 
(T./3) and (ass) respectively. I 

2.3 A Simple Programming Language 

In this section we take a programming language perspective by introducing a simple programming 
language, whose terms are interpreted by morphisms of the Kleisli category for a monad. Unlike 
the metalanguage of Section 2.2, the programming language does not allow to consider more than 
one monad at once. 

The interpretation in the Kleisli category can also be given indirectly via a translation in the 
simple metalanguage of Section 2.2 mapping programs of type r into terms of type Tt. If we try to 
establish a correspondence between equational theories of the simple programming language and 
categories with one monad (as done for the metalanguage), then we run into problems, since there 
is no way (in general) to recover C from Ct■ What we do instead is to establish a correspondence 
between theories with equivalence and existence assertions and categories with one monad satisfying 
the mono requirement, i.e. t]a is mono for every object A (note that tjta is always a mono, because 
Vta', ft A = At a ) ■ The intended extension of the existence predicate on computations of type A is 
the set of computations of the form [u] for some value v of type A, so it is natural to require t]a to 
be mono and interpret the existence predicate as the subobject corresponding to q a ■ 

The simple programming language is parametric in a signature, i.e. a set of base types and 
unary command symbols. To stress that the interpretation is in Ct rather than C, we use unary 
command symbols p: —>■ x 2 (instead of unary function symbols f: fi —> 72), we call x: n \~ p i e: 72 
a program (instead of a term) and write _ = T _ (instead of _ =t t -) as equality of computations 
of type r. Given a category C with a Kleisli triple (T, 77, _*) satisfying the mono requirement, an 
interpretation [_] of the programming language is parametric in an interpretation of the symbols 
in the signature and is defined by induction on the derivation of well-formedness for types, terms 
and equations (see Table 5) following the same pattern given for many sorted monadic equational 
logic, but with C replaced by Ct, namely: 

• the interpretation [r] of a (base) type r is an object of Ct, or equivalently an object of C 

• the interpretation [p] of an unary command p: t\ 72 is a morphism from [n] to [72] in 
Ct, or equivalently a morphism from [n] to T[t 2] in C: similarly for the interpretation of a 
program x : n \~ p i e: 72 

• the interpretation of an equivalence or existence assertion is a truth value. 

Remark 2.6 The let-constructor play a fundamental role: operationally it corresponds to sequen¬ 
tial evaluation of programs and categorically it corresponds to composition in the Kleisli category 
Ct (while substitution corresponds to composition in C). In the A v -calculus (let x<=e in e') is treated 
as syntactic sugar for (Xx.e')e. We think that this is not the right way to proceed, because it ex¬ 
plains the let-constructor (i.e. sequential evaluation of programs) in terms of constructors available 
only in functional languages. On the other hand, (let a^eine') cannot be treated as syntactic 
sugar for [e/x]e' (involving only the more primitive substitution) without collapsing computations 
to values. 

The existence predicate e { is inspired by the logic of partial terms/elements (see [Fou77, Sco79, 
Mog88]); however, there are important differences, e.g. 

x:t\~ p i p(e) l T2 

strict ---;- p: Ti —>• 72 

x: t h p i e l Tl 

is admissible for partial computations, but not in general. For certain notions of computation there 
may be other predicates on computations worth considering, or the existence predicate itself may 
have a more specialised meaning, for instance: 
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| RULE | SYNTAX SEMANTICS 


A 


b P i A type = [A] 

T 

1 ~pi t type = c 

b P i Tt type = Tc 


\~ P i r type = c 

x : t b p i x\T = Vc 

p: n ->• r 2 

x: t - p i ei; rj = g 

x:t \~ p i p(ei):r 2 = g; [p]* 

[-] 

x- t b p i e:r' = g 

x:t\~ p i [e\ : Tt' = g; 

M 

x: t b p i e: Tt' = g 

x:t\~ p i /x(e): t-' = 

let 

x:rb p ;ei:ri = 

aq: 7"i b p ; e 2 : r 2 = <? 2 

x:rbp( (letxi<^eiine 2 ):r 2 = gi;g2* 

eq 

x: n b p i ei: r 2 = 51 

x: ri b p i e 2 : r 2 = £f 2 

x: ri b p z ei = T2 e 2 g 1 = <ji 2 

ex 

x: n b p z e: r 2 =5 

7-i b p z e | T2 <S=> 3 !/i: [nj -*■ [r 2 ] s.t. g = h; 7?[ T2 j 


Table 5: Interpretation of the Simple Programming Language 
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refl Elhi±Il 
x : t \- p i e = Ti 


trans ■ 

congr ■ 

E.x ■ 
E.congr ■ 
subst ■ 


r ei = Tl e2 


r \- p i e 2 =n ei 
r b pi ei =n 


c: r hpi e 2 = Tl 


x: t \~ p i e 2 =Tl e 3 
x: r b p i e\ = Tl e 2 _ 
x: t b p i p(ei) = T2 p(e 2 ) P ‘ Tl T2 
I ~pi t type 

X: T \~pl X l T 

x: t b p i ei = Tl e 2 x: r h p ; e 1 | Tl 
x: t b p i e 2 | Tl 
b p ; e | Tl x: n b p ; 0 


r bp; [e/a:] 0 


Table 6: General Inference Rules 


• a partial computation exists iff it terminates; 

• a non-deterministic computation exists iff it gives exactly one result; 

• a computation with side-effects exists iff it does not change the store. 

Programs can be translated into terms of the metalanguage via a translation _° s.t. for every well- 
formed program x: n \~ p i e: r 2 the term x: n b m i e°: T r 2 is well-formed and [x: n b p ; e: r 2 ] = 
[x: Ti b TO ; e°: Tr 2 ] (the proof of these properties is left to the reader). 

Definition 2.7 Given a signature £ for the programming language, let £° be the signature for the 
metalanguage with the same base types and a function p:ri —> Tt 2 for each command p:Ti —*• r 2 
in £. The translation _° from programs over £ to terms over £° is defined by induction on raw 
programs: 

• x° = [x\t 

• (let xi<^=ei ine 2 )° = (letr x\<=e\° ine 2 °) 

• p(ei)° = (letr x<^=ei° inp(x)) 

• [e]° = [e°]x 

• p(e)° = (letr x<^=e° in x) 

The inference rules for deriving equivalence and existence assertions of the simple programming 
language can be partitioned as follows: 

• general rules (see Table 6) for terms denoting computations, but with variables ranging over 
values; these rules replace those of Table 2 for many sorted monadic equational logic 

• rules capturing the properties of type- and term-constructors (see Table 7) after interpretation 
of the programming language; these rules replace the additional rules for the metalanguage 
given in Table 4. 
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[-R 

m 


n4 




H.r] 

let.£ 


unit 


let./? 


let.p 


r I - P i ei = Tl e 2 


x : r b p i [ei] =tti 

N 

x:r b p i ei:n 


x: t \- p i [ei] |tti 


a;: r b p ; ei = Tt 

I e 2 

x: r b pi = Tl 

M e 2 ) 

x:t \~ p i evn 


x:t\~ MM) = T1 

ei 

x : r b p * ei |t t 


x: r b [/i(ei)] = T . 

n ei 

x: r b pi ei = n 

62 : 


X'■ Ti b p ; = T2 


b p i (let x'<=ei ine'J = T2 (let x'<=e2 ii 

T ^pi ei= n 


(let xi*^=ei inxi) e 

IiThpj Ki: Ti 


xp n b p ; e 2 : r 2 x 2 : r 2 b p ; e 3 : r 3 


r b p ; (let X2*t=(let xi<t=ei ine2) ii 
v: t b p i ei [ Tl xy 7% \~ p i e 2 : r 2 
r b p( (let xi<^ei ine2) = T2 [ei/xi]e2 

_ x:t\~ p i _ 

r \- p i p(ei) = Tl (let xi<s=ei inp(xi)) 1 


= T3 (let xi*t=ei in (let X2*t=e2ine3)) 


Table 7: Inference Rules of the Simple Programming Language 
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Soundness and completeness of the formal consequence relation w.r.t. interpretation of the 
simple programming language in categories with a monad satisfying the mono requirement is 
established in the usual way (see Section 2 . 1 ). The only step which differs is how to view a theory 
T of the simple programming language (i.e. a set of equivalence and existence assertions closed 
w.r.t. the inference rules) as a category E(T) with the required structure. 

Definition 2.8 Given a theory T of the simple programming language, the category TifT) is de¬ 
fined as follows: 

• objects are types r, 

• morphisms from n to T2 are equivalence classes [x: t\ \~ p i e: t 2 ] t of existing programs x: t% b p i 
e | T2 e T w.r.t. the equivalence relation induced by the theory T, i.e. 

(x: n h p i ei: r 2 ) = ( x: n \~ pi e 2 : r 2 ) (x\ n b pi a = T2 e 2 ) e T 

• composition is substitution, i.e. 

[x: ri h p i e\: r 2 ] r ; [x: r 2 b p i e 2 : r 3 ] r = [x: n I ~ p i [ei/x]e 2 : t 3 ] t 

• identity over r is [x: r b p i x: r] r . 

In order for composition in E(T) to be well-defined, it is essential to consider only equivalence 
classes of existing programs, since the simple programming language satisfies only a restricted form 
of substitutivity. 

Proposition 2.9 Every theory T of the simple programming language, viewed as a category !F(T), 
is equipped with a Kleisli triple (T, ry, _*) satisfying the mono requirement: 

• T(r) = Tt, 

• Vr = [x:t\~ p i [x\:Tt\ t , 

• {[x:t\ I - p i e:Tr 2 ] r )* = [x':Tt\ h p i [(let x<=[i.(x') in //(e))]: T r 2 ] T . 

Proof We have to show that the three axioms for Kleisli triples are valid. The validity of each axiom 
amounts to the derivability of an existence and equivalence assertion. For instance, q* = idr T is 
valid provided x':Tt \~ p i x' [t t and x':Tt \~ p i [(let x<=p,(x') ^^([a;]))] =t t x’ are derivable. The 
existence assertion follows immediately from (E.a;), while the equivalence is derived as follows: 

• x':Tt\- p i [(let x<=/j.(x') in/i([a;]))] = Tt [(let x^p{x’) inx)] 

by (/U./ 3 ), (refl) and (let.£) 

• x':Tt\~ p i [(let x<=/j.(x') in a:)] = Tt (/x(a^)] by (unit) and (let.£) 

• x'\Tt b p i [p(x’)\ =tt x' by (E.a;) and (p.r]) 

• x'-.Tt b p i [(let x<=p(x') in/i([a;]))] = Tt x 1 by (trans). 

We leave to the reader the derivation of the existence and equivalence assertions corresponding 
to the other axioms for Kleisli triples, and prove instead the mono requirement i.e. that fi',r] T = 
/ 2 ;ry r implies f\ = / 2 . Let /j be [ x:t' b p i e*:r] r , we have to derive x:t' b p i e\ = T e 2 from 
x: t' b p i [ei] =tt [e 2 ] (and x: t' b pt a | T ) : 

• x:t' b p i /i([ei]) =r M[e 2 ]) 

• x: t' b p i p{[ei\) = T ei 

• x: t' b p i ei = T e 2 
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by the first assumption and 

by {p.fl) 
by (trans). 





Remark 2.10 One can show that the canonical interpretation of a program x: ri \~ p i e: 72 in the 
category F{T) is the morphism [x: T\ b p[ [e]:Tr2] r . This interpretation establishes a one-one 
correspondence between morphisms from t\ to Tt 2 in the category !F(T), i.e. morphisms from n 
to 72 in the Kleisli category, and equivalence classes of programs x: n \~ p i e: T2 (not necessarely 
existing). The inverse correspondence maps a morphism [x: t\ \~ p i e': Tt 2 \ t to the equivalence class 
of x: t\ b p i fi(e '): 72. Indeed, x: t\ \~ p i e = T2 /z([e]) and x: t\ \~ p i e' = T2 [/a(e')] are derivable provided 
x: t, b p i e! |tt 2 - 

3 Extending the simple metalanguage 

So far we have considered only languages and formal systems for monadic terms x: t\ b e: r2, having 
exactly one free variable (occurring once). In this section we want to extend these languages (and 
formal systems) by allowing algebraic terms x-y: 7 %,..., x n : r n b e: r, having a finite number of free 
variables (occurring finitely many times) and investigate how this affects the interpretation and 
the structure on theories viewed as categories. For convenience in relating theories and categories 
with additional structure, we also allow types to be closed w.r.t. finite products 4 , in particular 
a typing context Xf. n,... ,x n : r n can be identified with a type. In general, the interpretation of 
an algebraic term aq: iq,..., x n : r n b e: r in a category (with finite products) is a morphism from 
(Ini x ... x Ir„l) to [t]. 

The extension of monadic equational logic to algebraic terms is equational logic, whose theories 
correspond to categories with finite products. We will introduce the metalanguage , i.e. the ex¬ 
tension of the simple metalanguage described in Section 2.2 to algebraic terms, and show that its 
theories correspond to categories with finite products and a strong monad , i.e. a monad and a natu¬ 
ral transformation t a,b- AxTB —> T(AxB). Intuitively t a,b transforms a pair value-computation 
into a computation of a pair of values, as follows 

a:A,c:TB (let y<=cin [(a, y}]): T(A x B) 

Remark 3.1 To understand why a category with finite products and a monad is not enough to 
interpret the metalanguage (and where the natural transformation t is needed), one has to look at 
the interpretation of a let-expression 

j r b m ; epTn r,a::Ti b TO ; e 2 :rr 2 
r \~ ml {let T x^e 1 me 2 ):TT2 

where T is a typing context. Let g\: c T cj and g2-cx c\ —> TC2 be the interpretations of T b TO j 
ei: Tti and Y,x:t\ b m ; 62: TVs respectively, where c is the interpretation of the typing context I 
and c.j is the interpretation of the type r,, then the interpretation of T b m ; (letr x<t=e,\ in 62): TY2 
ought to be a morphism g:c —> Tc2■ If (T, r/, /r) is the identity monad , i.e. T is the identity 
functor over C and r] and /j are the identity natural transformation over T, then computations get 
identified with values. In this case (letr x<=e\ ine2) can be replaced by [eq /a:]62, so g is simply 
(id c , <71}; g2- c —> C2. In the general case Table 3 suggests that _ above is indeed composition in 
the Kleisli category, therefore (id c ,gi};<72 should be replaced by (id c ,51); 52*- But in (id c ,51): 52* 
there is a type mismatch, since the codomain of (id c ,5i) is c x Tc\, while the domain of Tg\ is 
T(c x ci). The natural transformation t a,b-A x TB —> T(A x B) mediates between these two 
objects, so that g can be defined as (id c , rq); t CjCl ; 52*- 


4 If the metalanguage does not have finite products, we conjecture that its theories would no longer correspond to 
categories with finite products and a strong monad (even by taking as objects contexts and/or the Karoubi envelope, 
used in [Sco80] to associate a cartesian closed category to an untyped A-theory), but instead to multicategories with 
a Kleisli triple. We felt the greater generality (of not having products in the metalanguage) was not worth the 
mathematical complications. 
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Definition 3.2 A strong monad over a category C with (explicitly given) finite products is a 
monad (T,r],p) together with a natural transformation t a,b from A x TB to T(A x B) s.t. 


TA 



t AxB,C 

(Ax B) x TC -—> T((A x B) x C) 


Tola,b,c 

id^xtsc tA,BxC^ 

Ax (B x TC) -—fr A x T(B x C ) -> T(A x (B x C )) 

AxB 

id A x t) B | ^ 

t A.B 

AxTB -> T(A x B) 


id A x p B 


t A,TB Tt A ,E 

A x T 2 B -> T(A x TB) -> T 2 (A x B) 


where r and a are the natural isomorphisms 


r A : (1 x A) —► A , a A ,B,c : (A x B) x C —> A x (B x C) 

Remark 3.3 The diagrams above are taken from [Koc72], where a characterisation of strong mon¬ 
ads is given in terms of C-enriched categories (see [Kel82]). Kock fixes a commutative monoidal 
closed category C (in particular a cartesian closed category), and in this setup he establishes a 
one-one correspondence between strengths st a,b'-B a —> ( TB) ta and tensorial strengths t a ,b'-A® 
TB —> T(A® B) for a endofunctor T over C (see Theorem 1.3 in [Koc72]). Intuitively a strength 
st/i./j internalises the action of T on morphisms from A to B, and more precisely it makes (T, st) 
a C-enriched endofunctor on C enriched over itself (i.e. the hom-object C(A,B) is B A ). In this 
setting the diagrams of Definition 3.2 have the following meaning: 

• the first two diagrams are (1.7) and (1.8) in [Koc72], saying that t is a tensorial strength of 
T. So T can be made into a C-enriched endofunctor. 

• the last two diagrams say that r\\ Idc —+ T and g:T 2 —>■ T are C-enriched natural transfor¬ 
mations, where Idc, T and T 2 are enriched in the obvious way (see Remark 1.4 in [Koc72]). 

There is another purely categorical characterisation of strong monads, suggested to us by G. 
Plotkin, in terms of C-indexed categories (see [JP78]). Both characterisations are instances of a 
general methodological principle for studying programming languages (or logics) categorically (see 
[Mog89b]): 

when studying a complex language the 2-category Cat of small categories, functors and 
natural transformations may not be adequate; however, one may replace Cat with a 
different 2-category, whose objects captures better some fundamental structure of the 
language, while less fundamental structure can be modelled by 2-categorical concepts. 
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Monads are a 2-categorical concept, so we expect notions of computations for a complex language 
to be modelled by monads in a suitable 2-category. 

The first characterisation takes a commutative monoidal closed structure on C (used in [Laf88, 
See87] to model a fragment of linear logic), so that C can be enriched over itself. Then a strong 
monad over a cartesian closed category C is just a monad over C in the 2-category of C-enriched 
categories. 

The second characterisation takes a class V of display maps over C (used in [HP87] to model 
dependent types), and defines a C-indexed category C/x>_. Then a strong monad over a category 
C with finite products amounts to a monad over C/t>- in the 2-category of C-indexed categories, 
where V is the class of first projections (corresponding to constant type dependency). 

In general the natural transformation t has to be given explicitly as part of the additional 
structure. However, t is uniquely determined (but it may not exists) by T and the cartesian 
structure on C, when C has enough points. 

Proposition 3.4 (Uniqueness) If ( T, g, p) is a monad over a category C with finite products and 
enough points (i.e. V/i: 1 —> A.h; f = h;g implies f = g for any f,g:A^> B), then (T,g,p, t) is 
a strong monad over C if and only if t a,b is the unique family of morphisms s.t. for all points 
a: 1 —> A and b: 1 —> TB 

(a,by,tA,B = b-,T((\ B -a,id B )) 

where \ b :B —> 1 is the unique morphism from B to the terminal object. 

Proof Note that there is at most one t a,b s.t. (a, 6); t a,b = b-, T((\ B -, a, ids)) for all points a: 1 —> A 
and b: 1 —> TB, because C has enough points. 

First we show that if (T, g, p, t) is a strong monad, then t a,b satisfies the equation above. By 
naturality of t and by the first diagram in Definition 3.2 the following diagram commutes 



TB 


Since r B is an isomorphism (with inverse (!b, id/j)), then the two composite morphisms (a, 6); t a,b 
and (idi, 6); ttb\T( r B x )\T(ax ids) from 1 to T(Ax B) must coincide. But the second composition 
can be rewritten as 6; T((\ B -, a, ids)). 

Second we have to show that if t is the unique family of morphisms satisfying the equation 
above, then (T, g, p, t) is a strong monad. This amount to prove that t is a natural transformation 
and that the three diagrams in Definition 3.2 commute. The proof is a tedious diagram chasing, 
which relies on C having enough points. For instance, to prove that 1 i ; a; Tta = rxA it is enough 
to show that (idi, a); ti,^; Tta = (idi, a); tta for all points a: 1 —> A. I 


Example 3.5 We go through the monads given in Example 1.4 and show that they have a tensorial 
strength. 

• partiality TA = Tj_(= A + {_L}) 

t a,b(o, -1) = T and t a,b(o, b) = (a, b) (when b e B) 

• nondeterminism TA = Vfi n (A) 
t A,B(a,c) = {(a, b)\b € cj 
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• side-effects TA = (A x S) S 

UbKc) = (As: 5 .(let (6, s') = c(s) in ((a, 6), s'))) 

• exceptions TA = (A + E) 
tA,s(a,inr(e)) = inr(e) (when e G E) and 
tA,s(a,inl(6)) = inl((o,6)) (when b e B) 

• continuations TA = R( rA '> 

t a,b(o,c) = ( Xk:R AxB .c(Xb:B.k((a,b )))) 

• interactive input TA = (^7.A + 7 U ) 

tA b (a, c) is the tree obtained by replacing leaves of c labelled by b with the leaf labelled by 
(a,b) 

• interactive output TA = (/ry.A + (U x 7)) 

t A ,B(a,(s,b)) = {s,{a,b }). 

Remark 3.6 The tensorial strength t induces a natural transformation ^>a,b from TAx TB to 
T(A x B), namely 

^A,B = cta,tbAtb,a\ ( CtB,aAa,B )* 
where c is the natural isomorphism ca,b■ A x B —> B x A. 

The morphism ipA,B has the correct domain and codomain to interpret the pairing of a com¬ 
putation of type A with one of type B, obtained by first evaluating the first argument and then 
the second, namely 

c\\TA,C2’.TB (let x*^=ci in (let y*^=C2 in [(x, ?/)])): T(A x R) 

There is also a dual notion of pairing, 4 >a,b = cta,tbA b,a; Tcb,a (see [Koc 72 ]), which amounts 
to first evaluating the second argument and then the first. 

3.1 Interpretation and formal system 

We are now in a position to give the metalanguage for algebraic terms, its interpretation and 
inference rules. 

Definition 3.7 (metalanguage) An interpretation |_] of the metalanguage in a category C with 
terminal object l a- A —> 1 , binary products A\ x A2 -> A; and a strong monad (T, g, /i, t) 

is parametric in an interpretation of the symbols in the signature and is defined by induction on 
the derivation of well-formedness for types (see Table 8), terms and equations (see Table 9). 

Finite products nf 1 ’'" ,An : A\ x ... x A n —> A* used to interpret contexts and variables are defined 
by induction on n: 

0 Ai x ... x A 0 = 1 

n + 1 A\ x ... x A n+ i = (Ai x ... x A n ) x A n+ 1 

(An x... x A n ), A n+ i 
n 2 

^(Ai x...xA„),A„ +1 . jr A 1 ,..,A„ 

The inference rules for the metalanguage (see Table 10) are divided into three groups: 

• general rules for many sorted equational logic 

• rules for finite products 

• rules for T 
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RULE 

SYNTAX 

SEMANTICS 

A 





\~ m 

1 A type 

= [A] 

T 

\~ m 

i t type 

= c 


brr 

i Tt type 

= Tc 

1 





b„ 

i 1 type 

= 1 

X 

h m 

1 n type 

= Cl 



a t 2 type 

= c 2 


b ml ft x t 2 type 

= Cl X C2 

0 

b OT 

i Ti type (1 <i<n) 

= Ci 


X\ 

fjj r„ b 

= Cl X ... X c n 


Table 8: Interpretation of types in the Metalanguage 


Proposition 3.8 Every theory T of the metalanguage, viewed as a category E(T), is equipped 
with finite products and a strong monad whose tensorial strength is 

tri,T 2 = [x-.Ti X Tt2 I -ml (lety X 2 <=K 2 X in [(7T1X, X2)\t)'- T(ti X T2)\ T 

Proof Similar to that of Proposition 2.5 I 

Once we have a metalanguage for algebraic terms it is straightforward to add data-types charac¬ 
terised by universal properties and extend the categorical semantics accordingly 5 . For instance, if 
we want to have function spaces, then we simply require the category C (where the metalanguage 
is interpreted) to have exponentials B A and add the inference rules for the simply typed A-calculus 
(see Table 11) to those for the metalanguage. From a programming language perspective the situ¬ 
ation is more delicate. For instance, the semantics of functional types should reflect the choice of 
calling mechanism 6 : 

• in call-by-value a procedure of type A—>B expects a value of type A and computes a result 
of type B, so the interpretation of A —> B is (TB) ; 

• in call-by-name a procedure of type A —> B expects a computation of type A, which is 
evaluated only when needed, and computes a result of type B, so the interpretation of 
A -> B is ( TB) ta . 

In both cases the only exponentials needed to interpret the functional types of a programming 
language are of the form ( TB) A . By analogy with partial cartesian closed categories (pccc), where 
only p-exponentials are required to exists (see [Mog86, Ros86]), we adopt the following definition 
of A c -model: 


®The next difficult step in extending the metalanguage is the combination of dependent types and computations, 
which is currently under investigation. 

6 call-by-need does not have a simple categorical semantics, since the environment in which an expression is 
evaluated may itself undergo evaluation. 
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RULE|SYNTAX 

SEMANTICS 

var; 

\- m i n type (1 <i<n) = 

Ci 


X-f-Tt,. . . ,X n :T n \~ Xi'.Ti = 

^T"" Cn 

* 




Th*:l 

! i r i 

0 

n-ei:n 

91 


r 1- e 2 : r 2 = 

92 


r h (ei,e 2 ):n x r 2 = 

{91,92) 

TTi 

r h e: Ti x r 2 = 

9 


T h 7Tj(e): ri = 

g. ^ItiMt-2] 

f: n -*• r 2 

r ml &l' Ti ■— 

9 


r l- m ; f(ei):r 2 = 

s;-Pl 

[-]t 

r l- TO ; e: r = 

9 


n- TO ;[eJ T :Tr = 

9\ 

let 

ri"ml ei: Tri = 

91 


r, a;: ri b OT ; e 2 : Tr 2 = 

92 


T 1 uii (letr x<=ei ine 2 ): Tr 2 = 

(idirj^OUpi.in];^ 

eq 

r 1“ rni ^ 1*7" ~ 

9i 


r ml &2' T = 

92 


r b m j ei = T e 2 •<=>• 

9i = 92 


Table 9: Interpretation of terms in the Metalanguage 


20 







refl 

symm 

trans 

congr 

subst 

1.7? 

04 

x./9 

x.77 

144 

let.£ 

ass 

T./3 

T.r? 

app4 

A4 

->•/? 

-V 


T b e:r 
T b e = T e 


r b ei = T e2 

r b e2 = T ei 

r b e\ = T e-2 r b e2 = T 
r b e 2 = T e% 
r b ei = Tl e 2 f 
r b f( ei ) = T2 f(e 2 ) :T1_ " 

r b e: r r,x:rb^> 
r b [e/x]</> 


_C3 


T2 


Inference Rules of Many Sorted Equational Logic 


T b * =1 x 

r b ei = Tl r b ei = T2 e(j 

T b (ei,e 2 ) =nxT 2 (ei,e' 2 ) 
r b e\: n r b e 2 : r 2 
rbTT^ei.ea)) = Ti e* 

T b e: n x T2 

r b (7Ti(e),7r 2 (e)) = TlX r 2 e 

rules for product types 

r b m ; 6\ = T e 2 
r b TO ; [ei]r —tt [e2 ]t 

r b TO ; ei =m e2 T, x: ti b m ; =tt 2 e 2 
rb m j (letr x<=ei ine^) =t T2 (letT in 62) 

r b TO ; ei: Tri r,xi:n b m ; e 2 :Tr 2 r, x 2 : r 2 b mi e 3 : Tr 3 
r b TO ; (letr X2<^=(letT xi<=ei ine2) in63 ) =tt 3 (letTXi<*=eiin(letTX2<*=e2ine3)) 
rb m ;ei:n r,xi:n b m ; e 2 :rr 2 
T b m; (letr a:i^=[ei]T ine 2 ) =tt 2 [ei/xi]e 2 

_ r b ro ; ei: Tn _ 

T b m ; (letr xi^ei in [xi]t) =t Ti ei 


Table 10: Inference Rules of the Metalanguage 


T b eei = T2 e'e^ 

r, x: 7~i b ei = T2 e 2 _ 

T b (Ax: ri.ei) = Ti —>t 2 (Ax:ri.e 2 ) 
T b ei'.Ti r, x: Ti b e2:r2 
T b (Ax:ri.e2)ei = T2 [ei/x]e2 

rbe:n-»rj 


T b (Ax: ri.ex) = Tl 


DV(r) 


Table 11: rules for function spaces 
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Definition 3.9 A A c -model is a category C with finite products, a strong monad (T. rj, /i, t) satis¬ 
fying the mono requirement (i.e. t]a mono for every A e C) and T-exponential ( TB ) for every 
A,BeC. 

Remark 3.10 The definition of A c -model generalises that of pccc, in the sense that every pccc 
can be viewed as a A c -model. By analogy with p-exponentials, a T-exponential can be defined by 
giving an isomorphism Ct{C x A,B) = C(C, ( TB) A ) natural in C € C. We refer to [Mog89c] for 
the interpretation of a call-by-value programming language in a A c -model and the corresponding 
formal system, the A c -calculus. 

4 Strong monads over a topos 

In this section we show that, as far as monads or strong monads are concerned, we can assume 
w.l.o.g. that they are over a topos (see Theorem 4.9). The proof of Theorem 4.9 involves non¬ 
elementary notions from Category Theory, and we postpone it after discussing some applications, 
with particular emphasis on further extensions of the metalanguage and on conservative extension 
results. 

Let us take as formal system for toposes the type theory described in [LS86], this is a many 
sorted intuitionistic higher order logic with equality and with a set of types satisfying the following 
closure properties 7 : 

• the terminal object 1, the natural number object N and the subobject classifier are types 

• if A is a type, then the power object PA is a type 

• if A and B are types, then the binary product Ax B and the function space A —> B are 
types 

• if A is a type and <f: A —> is a predicate, then {x € A\(j>(x)} is a type. 

Notation 4.1 We introduce some notational conventions for formal systems: 

• MLt is the metalanguage for algebraic terms, whose set of types is closed under terminal 
object, binary products and TA: 

• AMLt is the extension of MLt with function spaces A —> B (interpreted as exponentials); 

• HML r is the type theory described above (see [LS86]) extended with objects of computations 
TA- 

• PL is the programming language for algebraic terms (see [Mog89c]); 

• A C PL is the extension of PL with function spaces A —*■ B (interpreted as T-exponentials), 
called A c -calculus in [Mog89c]. 

Definition 4.2 We say that a formal system (L2,\~2), where V(L 2) x L2 is a formal conse¬ 
quence relation 8 over L2, is a conservative extension of (T1,1-1) provided Li C L 2 and hi is 
the restriction of b 2 to V(L\) x L\. 

Theorem 4.3 HMLt is a conservative extension of ML 7 - and AMLy. In particular AML 7 - is a 
conservative extension of ML^. 


7 Lambek and Scott do not require closure under function spaces and subsets {x G A\<f>(x)}. 

8 For instance, in the case of ML7- the elements of L axe well-formed equality judgements T b m ; rfy e 2 and 
P b C iff there exists a derivation of C, where all assumptions are in P. 
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Proof The first result follows from Theorem 4.9, which implies that for every model C of MLt 
the Yoneda embedding maps the interpretation of an ML T -term in C to its interpretation in C, 
and the faithfulness of the Yoneda embedding, which implies that two ML^-terms have the same 
interpretation in C iff they have the same interpretation in C. The second result follows, because 
the Yoneda embedding preserves function spaces. The third conservative extension result follows 
immediately from the first two. I 

The above result means that we can think of computations naively in terms of sets and func¬ 
tions, provided we treat them intuitionistically, and can use the full apparatus of higher-order 
(intuitionistic) logic instead of the less expressive many sorted equational logic. 

Before giving a conservative extension result for the programming language, we have to express 
the mono requirement, equivalence and existence in HMLt- The idea is to extend the translation 
from PL-terms to MLy-terms given in Definition 2.7 and exploit the increased expressiveness of 
HMLt over ML7- to axiomatise the mono requirement and translate existence and equivalence 
assertions (see Remark 2.1): 

• the mono requirement for r, i.e. r] T is mono, is axiomatised by 

mono.T (Vz, y: t.[x\ t =t t [v]t x = T y) 

• the equalising requirement for r, i.e. i) T is the equaliser of T(rj T ) and rjfr , is axiomatised 
by (mono.r) and the axiom 

eqls.r (Va :-.Tt.[x\ t = t * t (let T y^xm[[y] T } T ) '-4 (3 \y:r.x = Tt [</]t)) 

• the translation _° is extended to assertions and functional types as follows: 

- (ei =r e 2 )° = ei° = Tt e 2 ° 

- ( ei | T )°l(3!x:T.e 1 °=TrMr) 

- (ti r 2 )° = Ti° -* Tt 2 ° 

Theorem 4.4 HMLt+ {(mono.r)| r type of PL} (i.e. t is built using only base types, 1, TA, and 
AxB) is a conservative extension of PL (after translation). Similarly, HMLT+{( mono - r )l r type o/A c PL} 
(i.e. t is built using only base types, 1, TA, AxB and A B) is a conservative extension of 
A C PL (after translation). 

Proof The proof proceeds as in the previous theorem. The only additional step is to show that for 
every type r of PL (or A C PL) the axiom (mono.T) holds in C, under the assumption that C satisfies 
the mono requirement. Let c be the interpretation of t in C (therefore Yc is the interpretation of 
t in C), then the axiom (mono.r) holds in C provided f)Y c is a mono. g c is mono (by the mono 
requirement), so f)Yc = Y (rj c ) is mono (as Y preserves monos). I 

In the theorem above only types from the programming language have to satisfy the mono require¬ 
ment. Indeed, HMLt + {(mono.r)| r type of HMLt} is not a conservative extension of PL (or 
A C PL). 

Lemma 4.5 If (T, g, p) is a monad over a topos C satisfying the mono requirement, then it satisfies 
also the equalising requirement. 

Proof See Lemma 6 on page 110 of [BW85]. I 

In other words, for any type r the axiom (eqls.r) is derivable in HMLt from the set of axioms 
{(mono.r) | r type of HMLt}. In general, when C is not a topos, the mono requirement does not 
entail the equalising requirement; one can easily define strong monads (over an Hey ting algebra) 
that satisfy the mono but not the equalising requirement (just take T(A) = A V B, for some 
element B ^ 1 of the Heyting algebra). In terms of formal consequence relation this means 
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that in HMLt + mono requirement the existence assertion T h p i e J. r is derivable from T h p i 
[e] =t t (let x^=ein [x]), while such derivation is not possible in A C PL. We do not know whether 
HMLt + equalising requirement is a conservative extension of PL + equalising requirement, or 
whether A C PL is a conservative extension of PL. 

A language which combines computations and higher order logic, like HMLt, seems to be the 
ideal framework for program logics that go beyond proving equivalence of programs, like Hoare’s 
logic for partial correctness of imperative languages. In HMLt (as well as MLt and PL) one can 
describe a programming language by introducing additional constant and axioms. In AMLt or 
A C PL such constants correspond to program-constructors, for instance: 

• lookup: L —> TU, which given a location l £ L produces the value of such location in the 
current store, and update: L x U —> Tl, which changes the current store by assigning to l £ L 
the value u £ [/; 

• if: Bool x TA x TA —> TA and while: T(Bool) x Tl —> Tl; 

• new: 1 —> TL, which returns a newly created location; 

• read: 1 —* TU, which computes a value by reading it from the input, and write: U —> Tl, 
which writes a value u £ U on the output. 

In HML t one can describe also a program logic, by adding constants p:TA^ Cl corresponding to 
properties of computations. 

Example 4.6 Let T be the monad for non-deterministic computations (see Example 1.4), then we 
can define a predicate may: A x TA —> Cl such that may (a, c) is true iff the value a is a possible 
outcome of the computation c (i.e. a £ c). However, there is a more uniform way of defining the 
may predicate for any type. Let O: TCI —» Cl be the predicate such that O(X) = T iff T £ X, 
where Cl is the set {_L, T} (note that 0(_) = maylft ,Jf). Then, may(a,c) can be defined as 
0(letT x^=cin [a = T x]t). 

The previous example suggests that predicates defined uniformly on computations of any type 
can be better described in terms of modal operators 7: TCI —*■ Cl, relating a computation of truth 
values to a truth value. This possibility has not been investigated in depth, so we will give only a 
tentative definition. 

Definition 4.7 If {T,r],p) is a monad over a topos C, then a T-modal operator is a T-algebra 
r-TCl Cl, i.e. 



TCI -> Cl 

7 


where Cl is the subobject classifier in C. 

The commutativity of the two diagrams above can be expressed in the metalanguage: 

• .r:U> 7 ([z]t) <—+ x 

• c: T 2 Cl h q(let x<=cva.x) <—* 7(let x<=cm. [7(*)]t) 

We consider some examples and non-examples of modal operators. 

Example 4.8 For the monad T of non-deterministic computations (see Example 1.4) there are 
only two modal operators □ and O: 

• D(A) = T iff T £ X; 
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• O(X) = T iff T e x. 

Given a nondeterministic computation e of type r and a predicate A(x) over r, i.e. a term of type 
fi, then □(letTar-^ein [A(s;)]t) is true iff all possible results of e satisfy A(x). 

For the monad T of computations with side-effects (see Example 1.4) there is an operator 
□ : (Cl x S) s — * Cl that can be used to express Hoare’s triples: 

• □/ iff for all s £ S there exists s' £ S s.t. fs *==|T ,$') 

this operator does not satisfy the second equivalence, as only one direction is valid, namely 
c: T 2 Cl h q(let x<=cm. [7(0 :)]t) •—> 7(let x<=cxnx) 

Let P:U —> Cl and Q: U x U —> Cl be predicates over storable values, e £ T1 a computation of type 
1 and x,y £ L locations. The intended meaning of the triple {P(x)}e{Q(x, y)} is “if in the initial 
state the content u of x satisfies P(u), then in the final state (i.e. after executing e) the content 
v of y satisfies Q(u. v)” . This intended meaning can be expressed formally in terms of the modal 
operator □ and the program-constructors lookup and update as follows: 

V«: U.P(u) —► a(let T v<=(update(x, u): e; lookup(y)) in [Q(u, w)]t) 

where _: TA x TB —> TB is the derived operation ei; e2 ^ (letr x<=ei ine2) with x not free in e2- 

Finally, we state the main theorem and outline its proof. In doing so we assume that the reader 
is familiar with non-elementary concepts from Category Theory. 

Theorem 4.9 Let C be a small category, C the topos of presheaves over C and Y the Yoneda 
embedding of C into C. Then for every monad (T, y, y) overC, there exists a monad () over 
C such that the following diagram commutes 9 



and for all a GC the following equations hold 


flYa=y(Va) , dYa=X(da) 

Moreover, for every strong monad ( T , y, p, t) over C, there exists a natural transformation t such 
that ( T , r), p, t) is a strong monad over C and for all a,b £ C the following equation holds 

tYa,Y6 = Y(t„, 6 ) 

where we have implicitly assume that the Yoneda embedding preserves finite products on the nose, 
i.e. the following diagrams commute 



C < - C x C 


9 This is a simplifying assumption. For our purposes it would be enough to have a natural isomorphism a: T; Y —> 
Y; T, but then the remaining equations have to be patched. For instance, the equation relating r) and fj would become 
»7Yo = Y (r)a)\<T a - 
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and for all a,b £ C. the following equations hold 

! Ya = Y(! a ) , nJ a ’ Yb = Y(tt“’ 6 ) 

Definition 4.10 ([Mac71]) Let T:C —> T> be a functor between two small categories and A a 
cocomplete category. Then, the left Kan extension L^:A C —* A v is the left adjoint of A T and 
can be defined as follows: 

L$(F)(d) = Colim^Tr; F) 

where F:C A , d £ D, T [ d is the comma category whose objects are pairs (c £ C, f:Tc —> d !}, 
7 r.T | d —> C is the projection functor (mapping a pair (c,f) to c) and Colinij -.A 1 —> A (with I 
small category) is a functor mapping an I-diagram in A to its colimit. 

The following proposition is a 2-categorical reformulation of Theorem 1.3.10 of [MR77]. For the 
sake of simplicity, we use the strict notions of 2-functor and 2-natural transformation, although we 
should have used pseudo-functors and pseudo-natural transformations. 

Proposition 4.11 Let Cat be the 2-category of small categories, CAT the 2-category of locally 
small categories and Cat — > CAT the inclusion 2-functor. Then, the following 2: Cat —> CAT 
is a 2-functor 

• ifC is a small category, then C is the topos of presheaves Set c 

• if T:C —» D is a functor, then T is the left Kan extension Lf.®* 

• if cr: S —> T:C —> D is a natural transformation and F £ C, then b f is the natural transfor¬ 
mation corresponding to id^, F via the following sequence of steps 

C(F, T op - TF) <——i V(TF, TF) 

C(F,a op ;TF) 

C(F, S op ; TF) i— V(SF,TF) 


Moreover, Y: _ —* 2 is a 2-natural transformation. 

Since monads are a 2-categorical concept (see [Str72]), the 2-functor 2 maps monads in Cat to 
monads in CAT. Then, the statement of Theorem 4.9 about lifting of monads follows immediately 
from Proposition 4.11. It remains to define the lifting t of a tensorial strength t for a monad (T, rj, p) 
over a small category C. 

Proposition 4.12 If C is a small category with finite products and T is an endofunctor over 
C, then for every natural transformation t a y. a x Tb —> T(a x b) there exists a unique natural 
transformation tF,G'■ F x TG —> T(F x G) s.t. tyo.Y b = Y(t 0i &) for all a,b £C. 

Proof Every F £ C is isomorphic to the colimit ColiniY lF (7r; Yj (shortly Colim !: Y i), where Y is 
the Yoneda embedding of C into C. Similarly G is isomorphic to Colim^Yj. Both functors (_ x T_) 
and T(_ x _) from C x C to C preserves colimits (as T and _ x F are left adjoints) and commute 
with the Yoneda embedding (as Y (axb) = Y ax Yb and T(Y a) = Y (Ta)). Therefore, F x TG and 
T(F x G) are isomorphic to the colimits Colim i -Yi x T(Yj) and Colim i jT(Yi x Yj) respectively. 
Let t be the natural transformation we are looking for, then 


Y(t id ) . 

Yi x T(Yj) -> T(Yi x Yj) 


T(fx 


F x T(G) -> T(F x G) 

t F,G 
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for all /: Yi —» F and g:Yj —> 5 (by naturality of t and Wi,Yj = Y(fyj)). But there exists exactly 
one morphism tmaking the diagram above commute, as (U,j\i,j) is a morphism between 
diagrams in C of the same shape, and these diagrams have colimit cones (/ x Tg\f,g) and (T(f x 
9) I /> 9) respectively. I 

Remark 4.13 If T is a monad of partial computations, i.e. it is induced by a dominion M. on C 
s.t. P(C,M)(a,b) = C(a,Tb), then the lifting T is the monad of partial computations induced by 
the dominion M. on C, obtained by lifting M. to the topos of presheaves, as described in [Ros86]. 
For other monads, however, the lifting is not the expected one. For instance, if T is the monad 
of side-effects (_ x S) s , then T is not (in general) the endofunctor (_ x Y S) YS on the topos of 
presheaves. 


Conclusions and further research 

The main contribution of this paper is the category-theoretic semantics of computations and the 
general principle for extending it to more complex languages (see Remark 3.3 and Section 4), while 
the formal systems presented are a straightforward fallout, easy to understand and relate to other 
calculi. 

Our work is just an example of what can be achieved in the study of programming languages 
by using a category-theoretic methodology, which avoids irrelevant syntactic detail and focus in¬ 
stead on the important structures underlying programming languages. We believe that there is a 
great potential to be exploited here. Indeed, in [Mog89b] we give a categorical account of phase 
distinction and program modules, that could lead to the introduction of higher order modules in 
programming languages like ADA or ML (see [HMM90]), while in [Mog89a] we propose a “modular 
approach” to Denotational Semantics based on the idea of monad-constructor (i.e. an endofunctor 
on the category of monads over a category C). 

The metalanguage open also the possibility to develop a new Logic of Computable Functions 
(see [Sco69]), based on an abstract semantic of computations rather than domain theory, for 
studying axiomatically different notions of computation and their relations. Some recent work by 
Crole and Pitts (see [CP90]) has consider an extension of the metalanguage equipped with a logic 
for inductive predicates, which goes beyond equational reasoning. A more ambitious goal would 
be to try exploiting the capabilities offered by higher-order logic in order to give a uniform account 
of various program logics, based on the idea of “T-modal operator” (see Definition 4.7). 

The semantics of computations corroborates the view that (constructive) proofs and programs 
are rather unrelated, although both of them can be understood in terms of functions. Indeed, 
monads (and comonads) used to model logical modalities, e.g. possibility and necessity in modal 
logic or why not and of course of linear logic, usually do not have a tensorial strength. In general, 
one should expect types suggested by logic to provide a more fine-grained type system without 
changing the nature of computations. 

We have identified monads as important to model notions of computations, but computational 
monads seem to have additional properties, e.g. they have a tensorial stregth and may satisfy the 
mono requirement. It is likely that there are other properties of computational monads still to be 
identified, and there is no reason to believe that such properties have to be found in the literature 
on monads. 
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